//导入 express 模块
const express = require('express');
//创建 express 的服务器实例
const app = express();
const joi = require('@hapi/joi');

// 导入并配置 cors 中间件
const cors = require('cors');
app.use(cors());

// 配置解析 application/x-www-form-urlencoded 格式的表单数据表单数据的中间件
app.use(express.urlencoded({ extended: false }));

// 托管静态资源文件
app.use('/uploads', express.static('./uploads'));

// 一定要在路由之前，封装 res.cc 函数
app.use((req, res, next) => {
  // status默认值为1，表示失败
  // err的值可能是一个错误对象，也可能是一个错误的描述字符串
  res.cc = function (err, status = 1) {
    res.send({
      status,
      message: err instanceof Error ? err.message : err,
    });
  };
  next();
});

// 在路由之前配置解析 Token 的中间件
const expressJWT = require('express-jwt');
const config = require('./config');

const jwtAuth = expressJWT({
  secret: config.jwtSecretKey,
  algorithms: ['HS256'],
}).unless({
  path: [/^\/api\//],
});
app.use(jwtAuth);

// 导入并使用用户路由模块
const userRouter = require('./router/user');
app.use('/api', userRouter);
// 导入并使用用户信息路由模块
const userinfoRouter = require('./router/userinfo');
app.use('/my', userinfoRouter);
// 导入并使用文章分类的路由模块
const artCateRouter = require('./router/artcate');
app.use('/my/article', artCateRouter);
// 导入并使用文章路由模块
const articleRouter = require('./router/article');
app.use('/my/article', articleRouter);

// 定义错误级别中间件
app.use((err, req, res, next) => {
  // 数据验证失败
  if (err instanceof joi.ValidationError) return res.cc(err);
  // 身份认证失败后的错误
  if (err.name === 'UnauthorizedError') return res.cc('身份认证失败');
  // 未知错误
  res.cc(err);
});

//调用 app.listen 方法，指定端口号并启动web服务器
app.listen(3007, function () {
  console.log('api server running at http://127.0.0.1:3007');
});
